package cn.uexpo.lhz.domain;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class SendMessageExample {
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    public SendMessageExample() {
        oredCriteria = new ArrayList<Criteria>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andIdIsNull() {
            addCriterion("sendMessage.id is null");
            return (Criteria) this;
        }

        public Criteria andIdIsNotNull() {
            addCriterion("sendMessage.id is not null");
            return (Criteria) this;
        }

        public Criteria andIdEqualTo(Integer value) {
            addCriterion("sendMessage.id =", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotEqualTo(Integer value) {
            addCriterion("sendMessage.id <>", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThan(Integer value) {
            addCriterion("sendMessage.id >", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.id >=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThan(Integer value) {
            addCriterion("sendMessage.id <", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.id <=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdIn(List<Integer> values) {
            addCriterion("sendMessage.id in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotIn(List<Integer> values) {
            addCriterion("sendMessage.id not in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdBetween(Integer value1, Integer value2) {
            addCriterion("sendMessage.id between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotBetween(Integer value1, Integer value2) {
            addCriterion("sendMessage.id not between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andNameIsNull() {
            addCriterion("sendMessage.name is null");
            return (Criteria) this;
        }

        public Criteria andNameIsNotNull() {
            addCriterion("sendMessage.name is not null");
            return (Criteria) this;
        }

        public Criteria andNameEqualTo(String value) {
            addCriterion("sendMessage.name =", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameNotEqualTo(String value) {
            addCriterion("sendMessage.name <>", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameGreaterThan(String value) {
            addCriterion("sendMessage.name >", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameGreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.name >=", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameLessThan(String value) {
            addCriterion("sendMessage.name <", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameLessThanOrEqualTo(String value) {
            addCriterion("sendMessage.name <=", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameLike(String value) {
            addCriterion("sendMessage.name like", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameNotLike(String value) {
            addCriterion("sendMessage.name not like", value, "name");
            return (Criteria) this;
        }

        public Criteria andNameIn(List<String> values) {
            addCriterion("sendMessage.name in", values, "name");
            return (Criteria) this;
        }

        public Criteria andNameNotIn(List<String> values) {
            addCriterion("sendMessage.name not in", values, "name");
            return (Criteria) this;
        }

        public Criteria andNameBetween(String value1, String value2) {
            addCriterion("sendMessage.name between", value1, value2, "name");
            return (Criteria) this;
        }

        public Criteria andNameNotBetween(String value1, String value2) {
            addCriterion("sendMessage.name not between", value1, value2, "name");
            return (Criteria) this;
        }

        public Criteria andTelIsNull() {
            addCriterion("sendMessage.tel is null");
            return (Criteria) this;
        }

        public Criteria andTelIsNotNull() {
            addCriterion("sendMessage.tel is not null");
            return (Criteria) this;
        }

        public Criteria andTelEqualTo(String value) {
            addCriterion("sendMessage.tel =", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelNotEqualTo(String value) {
            addCriterion("sendMessage.tel <>", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelGreaterThan(String value) {
            addCriterion("sendMessage.tel >", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelGreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.tel >=", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelLessThan(String value) {
            addCriterion("sendMessage.tel <", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelLessThanOrEqualTo(String value) {
            addCriterion("sendMessage.tel <=", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelLike(String value) {
            addCriterion("sendMessage.tel like", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelNotLike(String value) {
            addCriterion("sendMessage.tel not like", value, "tel");
            return (Criteria) this;
        }

        public Criteria andTelIn(List<String> values) {
            addCriterion("sendMessage.tel in", values, "tel");
            return (Criteria) this;
        }

        public Criteria andTelNotIn(List<String> values) {
            addCriterion("sendMessage.tel not in", values, "tel");
            return (Criteria) this;
        }

        public Criteria andTelBetween(String value1, String value2) {
            addCriterion("sendMessage.tel between", value1, value2, "tel");
            return (Criteria) this;
        }

        public Criteria andTelNotBetween(String value1, String value2) {
            addCriterion("sendMessage.tel not between", value1, value2, "tel");
            return (Criteria) this;
        }

        public Criteria andItemIsNull() {
            addCriterion("sendMessage.item is null");
            return (Criteria) this;
        }

        public Criteria andItemIsNotNull() {
            addCriterion("sendMessage.item is not null");
            return (Criteria) this;
        }

        public Criteria andItemEqualTo(String value) {
            addCriterion("sendMessage.item =", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemNotEqualTo(String value) {
            addCriterion("sendMessage.item <>", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemGreaterThan(String value) {
            addCriterion("sendMessage.item >", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemGreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.item >=", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemLessThan(String value) {
            addCriterion("sendMessage.item <", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemLessThanOrEqualTo(String value) {
            addCriterion("sendMessage.item <=", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemLike(String value) {
            addCriterion("sendMessage.item like", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemNotLike(String value) {
            addCriterion("sendMessage.item not like", value, "item");
            return (Criteria) this;
        }

        public Criteria andItemIn(List<String> values) {
            addCriterion("sendMessage.item in", values, "item");
            return (Criteria) this;
        }

        public Criteria andItemNotIn(List<String> values) {
            addCriterion("sendMessage.item not in", values, "item");
            return (Criteria) this;
        }

        public Criteria andItemBetween(String value1, String value2) {
            addCriterion("sendMessage.item between", value1, value2, "item");
            return (Criteria) this;
        }

        public Criteria andItemNotBetween(String value1, String value2) {
            addCriterion("sendMessage.item not between", value1, value2, "item");
            return (Criteria) this;
        }

        public Criteria andCreatorIsNull() {
            addCriterion("sendMessage.creator is null");
            return (Criteria) this;
        }

        public Criteria andCreatorIsNotNull() {
            addCriterion("sendMessage.creator is not null");
            return (Criteria) this;
        }

        public Criteria andCreatorEqualTo(String value) {
            addCriterion("sendMessage.creator =", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorNotEqualTo(String value) {
            addCriterion("sendMessage.creator <>", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorGreaterThan(String value) {
            addCriterion("sendMessage.creator >", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorGreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.creator >=", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorLessThan(String value) {
            addCriterion("sendMessage.creator <", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorLessThanOrEqualTo(String value) {
            addCriterion("sendMessage.creator <=", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorLike(String value) {
            addCriterion("sendMessage.creator like", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorNotLike(String value) {
            addCriterion("sendMessage.creator not like", value, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorIn(List<String> values) {
            addCriterion("sendMessage.creator in", values, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorNotIn(List<String> values) {
            addCriterion("sendMessage.creator not in", values, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorBetween(String value1, String value2) {
            addCriterion("sendMessage.creator between", value1, value2, "creator");
            return (Criteria) this;
        }

        public Criteria andCreatorNotBetween(String value1, String value2) {
            addCriterion("sendMessage.creator not between", value1, value2, "creator");
            return (Criteria) this;
        }

        public Criteria andValidityIsNull() {
            addCriterion("sendMessage.validity is null");
            return (Criteria) this;
        }

        public Criteria andValidityIsNotNull() {
            addCriterion("sendMessage.validity is not null");
            return (Criteria) this;
        }

        public Criteria andValidityEqualTo(String value) {
            addCriterion("sendMessage.validity =", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityNotEqualTo(String value) {
            addCriterion("sendMessage.validity <>", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityGreaterThan(String value) {
            addCriterion("sendMessage.validity >", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityGreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.validity >=", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityLessThan(String value) {
            addCriterion("sendMessage.validity <", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityLessThanOrEqualTo(String value) {
            addCriterion("sendMessage.validity <=", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityLike(String value) {
            addCriterion("sendMessage.validity like", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityNotLike(String value) {
            addCriterion("sendMessage.validity not like", value, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityIn(List<String> values) {
            addCriterion("sendMessage.validity in", values, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityNotIn(List<String> values) {
            addCriterion("sendMessage.validity not in", values, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityBetween(String value1, String value2) {
            addCriterion("sendMessage.validity between", value1, value2, "validity");
            return (Criteria) this;
        }

        public Criteria andValidityNotBetween(String value1, String value2) {
            addCriterion("sendMessage.validity not between", value1, value2, "validity");
            return (Criteria) this;
        }

        public Criteria andCreatetimeIsNull() {
            addCriterion("sendMessage.createTime is null");
            return (Criteria) this;
        }

        public Criteria andCreatetimeIsNotNull() {
            addCriterion("sendMessage.createTime is not null");
            return (Criteria) this;
        }

        public Criteria andCreatetimeEqualTo(Date value) {
            addCriterion("sendMessage.createTime =", value, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeNotEqualTo(Date value) {
            addCriterion("sendMessage.createTime <>", value, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeGreaterThan(Date value) {
            addCriterion("sendMessage.createTime >", value, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeGreaterThanOrEqualTo(Date value) {
            addCriterion("sendMessage.createTime >=", value, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeLessThan(Date value) {
            addCriterion("sendMessage.createTime <", value, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeLessThanOrEqualTo(Date value) {
            addCriterion("sendMessage.createTime <=", value, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeIn(List<Date> values) {
            addCriterion("sendMessage.createTime in", values, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeNotIn(List<Date> values) {
            addCriterion("sendMessage.createTime not in", values, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeBetween(Date value1, Date value2) {
            addCriterion("sendMessage.createTime between", value1, value2, "createtime");
            return (Criteria) this;
        }

        public Criteria andCreatetimeNotBetween(Date value1, Date value2) {
            addCriterion("sendMessage.createTime not between", value1, value2, "createtime");
            return (Criteria) this;
        }

        public Criteria andStateIsNull() {
            addCriterion("sendMessage.state is null");
            return (Criteria) this;
        }

        public Criteria andStateIsNotNull() {
            addCriterion("sendMessage.state is not null");
            return (Criteria) this;
        }

        public Criteria andStateEqualTo(String value) {
            addCriterion("sendMessage.state =", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateNotEqualTo(String value) {
            addCriterion("sendMessage.state <>", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateGreaterThan(String value) {
            addCriterion("sendMessage.state >", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateGreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.state >=", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateLessThan(String value) {
            addCriterion("sendMessage.state <", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateLessThanOrEqualTo(String value) {
            addCriterion("sendMessage.state <=", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateLike(String value) {
            addCriterion("sendMessage.state like", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateNotLike(String value) {
            addCriterion("sendMessage.state not like", value, "state");
            return (Criteria) this;
        }

        public Criteria andStateIn(List<String> values) {
            addCriterion("sendMessage.state in", values, "state");
            return (Criteria) this;
        }

        public Criteria andStateNotIn(List<String> values) {
            addCriterion("sendMessage.state not in", values, "state");
            return (Criteria) this;
        }

        public Criteria andStateBetween(String value1, String value2) {
            addCriterion("sendMessage.state between", value1, value2, "state");
            return (Criteria) this;
        }

        public Criteria andStateNotBetween(String value1, String value2) {
            addCriterion("sendMessage.state not between", value1, value2, "state");
            return (Criteria) this;
        }

        public Criteria andExstr1IsNull() {
            addCriterion("sendMessage.exStr1 is null");
            return (Criteria) this;
        }

        public Criteria andExstr1IsNotNull() {
            addCriterion("sendMessage.exStr1 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr1EqualTo(String value) {
            addCriterion("sendMessage.exStr1 =", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1NotEqualTo(String value) {
            addCriterion("sendMessage.exStr1 <>", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1GreaterThan(String value) {
            addCriterion("sendMessage.exStr1 >", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr1 >=", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1LessThan(String value) {
            addCriterion("sendMessage.exStr1 <", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr1 <=", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1Like(String value) {
            addCriterion("sendMessage.exStr1 like", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1NotLike(String value) {
            addCriterion("sendMessage.exStr1 not like", value, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1In(List<String> values) {
            addCriterion("sendMessage.exStr1 in", values, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1NotIn(List<String> values) {
            addCriterion("sendMessage.exStr1 not in", values, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1Between(String value1, String value2) {
            addCriterion("sendMessage.exStr1 between", value1, value2, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr1NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr1 not between", value1, value2, "exstr1");
            return (Criteria) this;
        }

        public Criteria andExstr2IsNull() {
            addCriterion("sendMessage.exStr2 is null");
            return (Criteria) this;
        }

        public Criteria andExstr2IsNotNull() {
            addCriterion("sendMessage.exStr2 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr2EqualTo(String value) {
            addCriterion("sendMessage.exStr2 =", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2NotEqualTo(String value) {
            addCriterion("sendMessage.exStr2 <>", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2GreaterThan(String value) {
            addCriterion("sendMessage.exStr2 >", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr2 >=", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2LessThan(String value) {
            addCriterion("sendMessage.exStr2 <", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr2 <=", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2Like(String value) {
            addCriterion("sendMessage.exStr2 like", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2NotLike(String value) {
            addCriterion("sendMessage.exStr2 not like", value, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2In(List<String> values) {
            addCriterion("sendMessage.exStr2 in", values, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2NotIn(List<String> values) {
            addCriterion("sendMessage.exStr2 not in", values, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2Between(String value1, String value2) {
            addCriterion("sendMessage.exStr2 between", value1, value2, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr2NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr2 not between", value1, value2, "exstr2");
            return (Criteria) this;
        }

        public Criteria andExstr3IsNull() {
            addCriterion("sendMessage.exStr3 is null");
            return (Criteria) this;
        }

        public Criteria andExstr3IsNotNull() {
            addCriterion("sendMessage.exStr3 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr3EqualTo(String value) {
            addCriterion("sendMessage.exStr3 =", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3NotEqualTo(String value) {
            addCriterion("sendMessage.exStr3 <>", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3GreaterThan(String value) {
            addCriterion("sendMessage.exStr3 >", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr3 >=", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3LessThan(String value) {
            addCriterion("sendMessage.exStr3 <", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr3 <=", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3Like(String value) {
            addCriterion("sendMessage.exStr3 like", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3NotLike(String value) {
            addCriterion("sendMessage.exStr3 not like", value, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3In(List<String> values) {
            addCriterion("sendMessage.exStr3 in", values, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3NotIn(List<String> values) {
            addCriterion("sendMessage.exStr3 not in", values, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3Between(String value1, String value2) {
            addCriterion("sendMessage.exStr3 between", value1, value2, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr3NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr3 not between", value1, value2, "exstr3");
            return (Criteria) this;
        }

        public Criteria andExstr4IsNull() {
            addCriterion("sendMessage.exStr4 is null");
            return (Criteria) this;
        }

        public Criteria andExstr4IsNotNull() {
            addCriterion("sendMessage.exStr4 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr4EqualTo(String value) {
            addCriterion("sendMessage.exStr4 =", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4NotEqualTo(String value) {
            addCriterion("sendMessage.exStr4 <>", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4GreaterThan(String value) {
            addCriterion("sendMessage.exStr4 >", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr4 >=", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4LessThan(String value) {
            addCriterion("sendMessage.exStr4 <", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr4 <=", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4Like(String value) {
            addCriterion("sendMessage.exStr4 like", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4NotLike(String value) {
            addCriterion("sendMessage.exStr4 not like", value, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4In(List<String> values) {
            addCriterion("sendMessage.exStr4 in", values, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4NotIn(List<String> values) {
            addCriterion("sendMessage.exStr4 not in", values, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4Between(String value1, String value2) {
            addCriterion("sendMessage.exStr4 between", value1, value2, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr4NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr4 not between", value1, value2, "exstr4");
            return (Criteria) this;
        }

        public Criteria andExstr5IsNull() {
            addCriterion("sendMessage.exStr5 is null");
            return (Criteria) this;
        }

        public Criteria andExstr5IsNotNull() {
            addCriterion("sendMessage.exStr5 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr5EqualTo(String value) {
            addCriterion("sendMessage.exStr5 =", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5NotEqualTo(String value) {
            addCriterion("sendMessage.exStr5 <>", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5GreaterThan(String value) {
            addCriterion("sendMessage.exStr5 >", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr5 >=", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5LessThan(String value) {
            addCriterion("sendMessage.exStr5 <", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr5 <=", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5Like(String value) {
            addCriterion("sendMessage.exStr5 like", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5NotLike(String value) {
            addCriterion("sendMessage.exStr5 not like", value, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5In(List<String> values) {
            addCriterion("sendMessage.exStr5 in", values, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5NotIn(List<String> values) {
            addCriterion("sendMessage.exStr5 not in", values, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5Between(String value1, String value2) {
            addCriterion("sendMessage.exStr5 between", value1, value2, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr5NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr5 not between", value1, value2, "exstr5");
            return (Criteria) this;
        }

        public Criteria andExstr6IsNull() {
            addCriterion("sendMessage.exStr6 is null");
            return (Criteria) this;
        }

        public Criteria andExstr6IsNotNull() {
            addCriterion("sendMessage.exStr6 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr6EqualTo(String value) {
            addCriterion("sendMessage.exStr6 =", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6NotEqualTo(String value) {
            addCriterion("sendMessage.exStr6 <>", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6GreaterThan(String value) {
            addCriterion("sendMessage.exStr6 >", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr6 >=", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6LessThan(String value) {
            addCriterion("sendMessage.exStr6 <", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr6 <=", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6Like(String value) {
            addCriterion("sendMessage.exStr6 like", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6NotLike(String value) {
            addCriterion("sendMessage.exStr6 not like", value, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6In(List<String> values) {
            addCriterion("sendMessage.exStr6 in", values, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6NotIn(List<String> values) {
            addCriterion("sendMessage.exStr6 not in", values, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6Between(String value1, String value2) {
            addCriterion("sendMessage.exStr6 between", value1, value2, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr6NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr6 not between", value1, value2, "exstr6");
            return (Criteria) this;
        }

        public Criteria andExstr7IsNull() {
            addCriterion("sendMessage.exStr7 is null");
            return (Criteria) this;
        }

        public Criteria andExstr7IsNotNull() {
            addCriterion("sendMessage.exStr7 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr7EqualTo(String value) {
            addCriterion("sendMessage.exStr7 =", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7NotEqualTo(String value) {
            addCriterion("sendMessage.exStr7 <>", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7GreaterThan(String value) {
            addCriterion("sendMessage.exStr7 >", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr7 >=", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7LessThan(String value) {
            addCriterion("sendMessage.exStr7 <", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr7 <=", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7Like(String value) {
            addCriterion("sendMessage.exStr7 like", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7NotLike(String value) {
            addCriterion("sendMessage.exStr7 not like", value, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7In(List<String> values) {
            addCriterion("sendMessage.exStr7 in", values, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7NotIn(List<String> values) {
            addCriterion("sendMessage.exStr7 not in", values, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7Between(String value1, String value2) {
            addCriterion("sendMessage.exStr7 between", value1, value2, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr7NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr7 not between", value1, value2, "exstr7");
            return (Criteria) this;
        }

        public Criteria andExstr8IsNull() {
            addCriterion("sendMessage.exStr8 is null");
            return (Criteria) this;
        }

        public Criteria andExstr8IsNotNull() {
            addCriterion("sendMessage.exStr8 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr8EqualTo(String value) {
            addCriterion("sendMessage.exStr8 =", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8NotEqualTo(String value) {
            addCriterion("sendMessage.exStr8 <>", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8GreaterThan(String value) {
            addCriterion("sendMessage.exStr8 >", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr8 >=", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8LessThan(String value) {
            addCriterion("sendMessage.exStr8 <", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr8 <=", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8Like(String value) {
            addCriterion("sendMessage.exStr8 like", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8NotLike(String value) {
            addCriterion("sendMessage.exStr8 not like", value, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8In(List<String> values) {
            addCriterion("sendMessage.exStr8 in", values, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8NotIn(List<String> values) {
            addCriterion("sendMessage.exStr8 not in", values, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8Between(String value1, String value2) {
            addCriterion("sendMessage.exStr8 between", value1, value2, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr8NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr8 not between", value1, value2, "exstr8");
            return (Criteria) this;
        }

        public Criteria andExstr9IsNull() {
            addCriterion("sendMessage.exStr9 is null");
            return (Criteria) this;
        }

        public Criteria andExstr9IsNotNull() {
            addCriterion("sendMessage.exStr9 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr9EqualTo(String value) {
            addCriterion("sendMessage.exStr9 =", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9NotEqualTo(String value) {
            addCriterion("sendMessage.exStr9 <>", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9GreaterThan(String value) {
            addCriterion("sendMessage.exStr9 >", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr9 >=", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9LessThan(String value) {
            addCriterion("sendMessage.exStr9 <", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr9 <=", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9Like(String value) {
            addCriterion("sendMessage.exStr9 like", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9NotLike(String value) {
            addCriterion("sendMessage.exStr9 not like", value, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9In(List<String> values) {
            addCriterion("sendMessage.exStr9 in", values, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9NotIn(List<String> values) {
            addCriterion("sendMessage.exStr9 not in", values, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9Between(String value1, String value2) {
            addCriterion("sendMessage.exStr9 between", value1, value2, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr9NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr9 not between", value1, value2, "exstr9");
            return (Criteria) this;
        }

        public Criteria andExstr10IsNull() {
            addCriterion("sendMessage.exStr10 is null");
            return (Criteria) this;
        }

        public Criteria andExstr10IsNotNull() {
            addCriterion("sendMessage.exStr10 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr10EqualTo(String value) {
            addCriterion("sendMessage.exStr10 =", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10NotEqualTo(String value) {
            addCriterion("sendMessage.exStr10 <>", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10GreaterThan(String value) {
            addCriterion("sendMessage.exStr10 >", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr10 >=", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10LessThan(String value) {
            addCriterion("sendMessage.exStr10 <", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr10 <=", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10Like(String value) {
            addCriterion("sendMessage.exStr10 like", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10NotLike(String value) {
            addCriterion("sendMessage.exStr10 not like", value, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10In(List<String> values) {
            addCriterion("sendMessage.exStr10 in", values, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10NotIn(List<String> values) {
            addCriterion("sendMessage.exStr10 not in", values, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10Between(String value1, String value2) {
            addCriterion("sendMessage.exStr10 between", value1, value2, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr10NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr10 not between", value1, value2, "exstr10");
            return (Criteria) this;
        }

        public Criteria andExstr11IsNull() {
            addCriterion("sendMessage.exStr11 is null");
            return (Criteria) this;
        }

        public Criteria andExstr11IsNotNull() {
            addCriterion("sendMessage.exStr11 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr11EqualTo(String value) {
            addCriterion("sendMessage.exStr11 =", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11NotEqualTo(String value) {
            addCriterion("sendMessage.exStr11 <>", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11GreaterThan(String value) {
            addCriterion("sendMessage.exStr11 >", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr11 >=", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11LessThan(String value) {
            addCriterion("sendMessage.exStr11 <", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr11 <=", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11Like(String value) {
            addCriterion("sendMessage.exStr11 like", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11NotLike(String value) {
            addCriterion("sendMessage.exStr11 not like", value, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11In(List<String> values) {
            addCriterion("sendMessage.exStr11 in", values, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11NotIn(List<String> values) {
            addCriterion("sendMessage.exStr11 not in", values, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11Between(String value1, String value2) {
            addCriterion("sendMessage.exStr11 between", value1, value2, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr11NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr11 not between", value1, value2, "exstr11");
            return (Criteria) this;
        }

        public Criteria andExstr12IsNull() {
            addCriterion("sendMessage.exStr12 is null");
            return (Criteria) this;
        }

        public Criteria andExstr12IsNotNull() {
            addCriterion("sendMessage.exStr12 is not null");
            return (Criteria) this;
        }

        public Criteria andExstr12EqualTo(String value) {
            addCriterion("sendMessage.exStr12 =", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12NotEqualTo(String value) {
            addCriterion("sendMessage.exStr12 <>", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12GreaterThan(String value) {
            addCriterion("sendMessage.exStr12 >", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12GreaterThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr12 >=", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12LessThan(String value) {
            addCriterion("sendMessage.exStr12 <", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12LessThanOrEqualTo(String value) {
            addCriterion("sendMessage.exStr12 <=", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12Like(String value) {
            addCriterion("sendMessage.exStr12 like", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12NotLike(String value) {
            addCriterion("sendMessage.exStr12 not like", value, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12In(List<String> values) {
            addCriterion("sendMessage.exStr12 in", values, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12NotIn(List<String> values) {
            addCriterion("sendMessage.exStr12 not in", values, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12Between(String value1, String value2) {
            addCriterion("sendMessage.exStr12 between", value1, value2, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExstr12NotBetween(String value1, String value2) {
            addCriterion("sendMessage.exStr12 not between", value1, value2, "exstr12");
            return (Criteria) this;
        }

        public Criteria andExt1IsNull() {
            addCriterion("sendMessage.ext1 is null");
            return (Criteria) this;
        }

        public Criteria andExt1IsNotNull() {
            addCriterion("sendMessage.ext1 is not null");
            return (Criteria) this;
        }

        public Criteria andExt1EqualTo(Integer value) {
            addCriterion("sendMessage.ext1 =", value, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1NotEqualTo(Integer value) {
            addCriterion("sendMessage.ext1 <>", value, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1GreaterThan(Integer value) {
            addCriterion("sendMessage.ext1 >", value, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1GreaterThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext1 >=", value, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1LessThan(Integer value) {
            addCriterion("sendMessage.ext1 <", value, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1LessThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext1 <=", value, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1In(List<Integer> values) {
            addCriterion("sendMessage.ext1 in", values, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1NotIn(List<Integer> values) {
            addCriterion("sendMessage.ext1 not in", values, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1Between(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext1 between", value1, value2, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt1NotBetween(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext1 not between", value1, value2, "ext1");
            return (Criteria) this;
        }

        public Criteria andExt2IsNull() {
            addCriterion("sendMessage.ext2 is null");
            return (Criteria) this;
        }

        public Criteria andExt2IsNotNull() {
            addCriterion("sendMessage.ext2 is not null");
            return (Criteria) this;
        }

        public Criteria andExt2EqualTo(Integer value) {
            addCriterion("sendMessage.ext2 =", value, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2NotEqualTo(Integer value) {
            addCriterion("sendMessage.ext2 <>", value, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2GreaterThan(Integer value) {
            addCriterion("sendMessage.ext2 >", value, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2GreaterThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext2 >=", value, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2LessThan(Integer value) {
            addCriterion("sendMessage.ext2 <", value, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2LessThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext2 <=", value, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2In(List<Integer> values) {
            addCriterion("sendMessage.ext2 in", values, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2NotIn(List<Integer> values) {
            addCriterion("sendMessage.ext2 not in", values, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2Between(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext2 between", value1, value2, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt2NotBetween(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext2 not between", value1, value2, "ext2");
            return (Criteria) this;
        }

        public Criteria andExt3IsNull() {
            addCriterion("sendMessage.ext3 is null");
            return (Criteria) this;
        }

        public Criteria andExt3IsNotNull() {
            addCriterion("sendMessage.ext3 is not null");
            return (Criteria) this;
        }

        public Criteria andExt3EqualTo(Integer value) {
            addCriterion("sendMessage.ext3 =", value, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3NotEqualTo(Integer value) {
            addCriterion("sendMessage.ext3 <>", value, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3GreaterThan(Integer value) {
            addCriterion("sendMessage.ext3 >", value, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3GreaterThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext3 >=", value, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3LessThan(Integer value) {
            addCriterion("sendMessage.ext3 <", value, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3LessThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext3 <=", value, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3In(List<Integer> values) {
            addCriterion("sendMessage.ext3 in", values, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3NotIn(List<Integer> values) {
            addCriterion("sendMessage.ext3 not in", values, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3Between(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext3 between", value1, value2, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt3NotBetween(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext3 not between", value1, value2, "ext3");
            return (Criteria) this;
        }

        public Criteria andExt4IsNull() {
            addCriterion("sendMessage.ext4 is null");
            return (Criteria) this;
        }

        public Criteria andExt4IsNotNull() {
            addCriterion("sendMessage.ext4 is not null");
            return (Criteria) this;
        }

        public Criteria andExt4EqualTo(Integer value) {
            addCriterion("sendMessage.ext4 =", value, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4NotEqualTo(Integer value) {
            addCriterion("sendMessage.ext4 <>", value, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4GreaterThan(Integer value) {
            addCriterion("sendMessage.ext4 >", value, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4GreaterThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext4 >=", value, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4LessThan(Integer value) {
            addCriterion("sendMessage.ext4 <", value, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4LessThanOrEqualTo(Integer value) {
            addCriterion("sendMessage.ext4 <=", value, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4In(List<Integer> values) {
            addCriterion("sendMessage.ext4 in", values, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4NotIn(List<Integer> values) {
            addCriterion("sendMessage.ext4 not in", values, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4Between(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext4 between", value1, value2, "ext4");
            return (Criteria) this;
        }

        public Criteria andExt4NotBetween(Integer value1, Integer value2) {
            addCriterion("sendMessage.ext4 not between", value1, value2, "ext4");
            return (Criteria) this;
        }

        public Criteria andTime1IsNull() {
            addCriterion("sendMessage.time1 is null");
            return (Criteria) this;
        }

        public Criteria andTime1IsNotNull() {
            addCriterion("sendMessage.time1 is not null");
            return (Criteria) this;
        }

        public Criteria andTime1EqualTo(Date value) {
            addCriterion("sendMessage.time1 =", value, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1NotEqualTo(Date value) {
            addCriterion("sendMessage.time1 <>", value, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1GreaterThan(Date value) {
            addCriterion("sendMessage.time1 >", value, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1GreaterThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time1 >=", value, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1LessThan(Date value) {
            addCriterion("sendMessage.time1 <", value, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1LessThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time1 <=", value, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1In(List<Date> values) {
            addCriterion("sendMessage.time1 in", values, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1NotIn(List<Date> values) {
            addCriterion("sendMessage.time1 not in", values, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1Between(Date value1, Date value2) {
            addCriterion("sendMessage.time1 between", value1, value2, "time1");
            return (Criteria) this;
        }

        public Criteria andTime1NotBetween(Date value1, Date value2) {
            addCriterion("sendMessage.time1 not between", value1, value2, "time1");
            return (Criteria) this;
        }

        public Criteria andTime2IsNull() {
            addCriterion("sendMessage.time2 is null");
            return (Criteria) this;
        }

        public Criteria andTime2IsNotNull() {
            addCriterion("sendMessage.time2 is not null");
            return (Criteria) this;
        }

        public Criteria andTime2EqualTo(Date value) {
            addCriterion("sendMessage.time2 =", value, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2NotEqualTo(Date value) {
            addCriterion("sendMessage.time2 <>", value, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2GreaterThan(Date value) {
            addCriterion("sendMessage.time2 >", value, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2GreaterThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time2 >=", value, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2LessThan(Date value) {
            addCriterion("sendMessage.time2 <", value, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2LessThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time2 <=", value, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2In(List<Date> values) {
            addCriterion("sendMessage.time2 in", values, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2NotIn(List<Date> values) {
            addCriterion("sendMessage.time2 not in", values, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2Between(Date value1, Date value2) {
            addCriterion("sendMessage.time2 between", value1, value2, "time2");
            return (Criteria) this;
        }

        public Criteria andTime2NotBetween(Date value1, Date value2) {
            addCriterion("sendMessage.time2 not between", value1, value2, "time2");
            return (Criteria) this;
        }

        public Criteria andTime3IsNull() {
            addCriterion("sendMessage.time3 is null");
            return (Criteria) this;
        }

        public Criteria andTime3IsNotNull() {
            addCriterion("sendMessage.time3 is not null");
            return (Criteria) this;
        }

        public Criteria andTime3EqualTo(Date value) {
            addCriterion("sendMessage.time3 =", value, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3NotEqualTo(Date value) {
            addCriterion("sendMessage.time3 <>", value, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3GreaterThan(Date value) {
            addCriterion("sendMessage.time3 >", value, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3GreaterThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time3 >=", value, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3LessThan(Date value) {
            addCriterion("sendMessage.time3 <", value, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3LessThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time3 <=", value, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3In(List<Date> values) {
            addCriterion("sendMessage.time3 in", values, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3NotIn(List<Date> values) {
            addCriterion("sendMessage.time3 not in", values, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3Between(Date value1, Date value2) {
            addCriterion("sendMessage.time3 between", value1, value2, "time3");
            return (Criteria) this;
        }

        public Criteria andTime3NotBetween(Date value1, Date value2) {
            addCriterion("sendMessage.time3 not between", value1, value2, "time3");
            return (Criteria) this;
        }

        public Criteria andTime4IsNull() {
            addCriterion("sendMessage.time4 is null");
            return (Criteria) this;
        }

        public Criteria andTime4IsNotNull() {
            addCriterion("sendMessage.time4 is not null");
            return (Criteria) this;
        }

        public Criteria andTime4EqualTo(Date value) {
            addCriterion("sendMessage.time4 =", value, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4NotEqualTo(Date value) {
            addCriterion("sendMessage.time4 <>", value, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4GreaterThan(Date value) {
            addCriterion("sendMessage.time4 >", value, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4GreaterThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time4 >=", value, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4LessThan(Date value) {
            addCriterion("sendMessage.time4 <", value, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4LessThanOrEqualTo(Date value) {
            addCriterion("sendMessage.time4 <=", value, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4In(List<Date> values) {
            addCriterion("sendMessage.time4 in", values, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4NotIn(List<Date> values) {
            addCriterion("sendMessage.time4 not in", values, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4Between(Date value1, Date value2) {
            addCriterion("sendMessage.time4 between", value1, value2, "time4");
            return (Criteria) this;
        }

        public Criteria andTime4NotBetween(Date value1, Date value2) {
            addCriterion("sendMessage.time4 not between", value1, value2, "time4");
            return (Criteria) this;
        }
    }

    public static class Criteria extends GeneratedCriteria {

        protected Criteria() {
            super();
        }
    }

    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}